上一篇文章: Python进程专题总览篇
下一篇文章:Python进程专题2:multiprocessing创建进程
该方法只能在unix/Linux/Mac上运行,windows不可以运行。

程序执行到fork()时,操作系统会创建一个新进程(子进程),并把父进程的所有信息赋值到子进程中。

这个方法很特殊,会有两次返回,分别在子进程和父进程返回一次,子进程永远返回0,父进程返回进程的id.

getpid():返回当前进程的id

getppid():返回当前进程父进程的id。

实例:

import os
id=os.fork()
index=0
if id<0:
    print("子进程创建失败了")
elif id==0:
    index+=1
    print("我是子进程(%d),我的父进程是:%d,index=%d"%(os.getpid(),os.getppid(),index))
else:
    index += 1
    print("我是父进程:%d,我的子进程是:%d,index=%d"%(os.getpid(),id,index))

结果:

我是父进程:9735,我的子进程是:9736,index=1
我是子进程(9736),我的父进程是:9735,index=1

从上面实例也可以看出:每个进程的所有数据(包括全局变量)都各持一份,互不影响。

多次fork()可发现:父子进程执行顺序没有规律,完全取决于操作系统的调度算法。


Mark
662 声望344 粉丝

talk is cheap,show me the code